<template>
  <div class="layout-padding">
    <div class="layout-padding-auto layout-padding-view">
      <div class="flex-margin" style="width: 400px">
        <el-result icon="warning" title="动态路由" subTitle="可 `开启 TagsView 共用` 进行单标签测试">
          <template #extra>
            <el-alert type="success" :closable="false" class="mb30">
              <template #default>
                <div>1、设置非国际化：格式：tagsViewName=xxx</div>
                <br />
                <div>2、设置国际化：格式：tagsViewName=JSON.stringify({"zh-cn":"测试用","en":"test+page","zh-tw":"測試用"})</div>
                <br />
                <div>3、设置国际化后，去顶栏切换语言查看演示效果</div>
                <br />
              </template>
            </el-alert>
            <el-input v-model="state.tagsViewName" placeholder="请输入tagsView 名称" clearable class="mb15" style="width: 400px"></el-input>
            <el-input v-model="state.value" placeholder="请输入路由参数id值" clearable style="width: 400px"></el-input>
            <el-button type="primary" class="mt15" @click="onGoDetailsClick">
              <SvgIcon name="iconfont icon-dongtai" />
              动态路由传参
            </el-button>
            <el-button type="primary" class="mt15" @click="onChangeI18n">
              <SvgIcon name="iconfont icon-fuhao-zhongwen" />
              {{ state.tagsViewNameIsI18n ? '普通的演示' : '国际化演示' }}
            </el-button>
          </template>
        </el-result>
      </div>
    </div>
  </div>
</template>

<script setup lang="ts" name="example/paramsDynamic">
import { reactive } from 'vue'
import { useRouter } from 'vue-router'
import { ElMessage } from 'element-plus'

// 定义变量内容
const router = useRouter()
const state = reactive<ParamsState>({
  value: '',
  tagsViewName: '',
  tagsViewNameIsI18n: false,
})

// 跳转到详情
const onGoDetailsClick = () => {
  if (!state.tagsViewName) return ElMessage.warning('动态路由tagsViewName为必填，因为路由配置了')
  if (!state.value) return ElMessage.warning('路由参数id值为必填')
  // name 值为路由中的 name
  router.push({
    name: 'example/paramsDynamicDetails',
    params: {
      t: 'vue-next-admin',
      id: state.value,
      tagsViewName: state.tagsViewName,
    },
  })
  state.value = ''
}
// 模拟测试内容
const onChangeI18n = () => {
  state.tagsViewNameIsI18n = !state.tagsViewNameIsI18n
  if (state.tagsViewNameIsI18n) {
    state.tagsViewName = JSON.stringify({
      'zh-cn': '我是动态路由',
      en: 'Im dynamic routing',
      'zh-tw': '我是動態路由',
    })
  } else {
    state.tagsViewName = '我是动态路由测试tagsViewName(非国际化)'
  }
}
</script>
